import router from '@/router'
import NProgress from 'nprogress' // 引入一份进度条插件
import 'nprogress/nprogress.css'
import store from '@/store'

const whiteList = ['/login', '404'] // 定义白名单

// 前置守卫
router.beforeEach(function(to, from, next) {
  NProgress.start() // 开启进度条
  // 判断有无token
  if (store.getters.token) {
    if (to.path === '/login') { // 判断是否去登录页
      next('/') // 禁止去登录页 导向主页
      NProgress.done() // 关闭进度条
    } else {
      next()
    }
  } else { // 如果没有token 判断
    if (whiteList.indexOf(to.path) !== -1) { // 找到数组中指定元素的索引 如果找不到返回-1
      next() // 白名单里有 放行
    } else {
      next('/login') // 导向登录页
      NProgress.done() // 关闭进度条
    }
  }
})

// 后置守卫
router.afterEach(function() {
  NProgress.done() // 关闭进度条
})
